<?xml version='1.0' encoding='utf-8'?>
<html xmlns="http://www.w3.org/1999/xhtml">
  <head>
    <title>Pro Git - 简体中文版
</title>
    <meta content="http://www.w3.org/1999/xhtml; charset=utf-8" http-equiv="Content-Type"/>
    <link href="stylesheet.css" type="text/css" rel="stylesheet"/>
    <style type="text/css">
		@page { margin-bottom: 5.000000pt; margin-top: 5.000000pt; }</style>
  </head>
  <body class="calibre">
<h2 id="calibre_toc_14" class="calibre3">初次运行 Git 前的配置</h2>

<p class="calibre2">一般在新的系统上，我们都需要先配置下自己的 Git 工作环境。配置工作只需一次，以后升级时还会沿用现在的配置。当然，如果需要，你随时可以用相同的命令修改已有的配置。</p>

<p class="calibre2">Git 提供了一个叫做 git config 的工具（译注：实际是 git-config 命令，只不过可以通过 git 加一个名字来呼叫此命令。），专门用来配置或读取相应的工作环境变量。而正是由这些环境变量，决定了 Git 在各个环节的具体工作方式和行为。这些变量可以存放在以下三个不同的地方：</p>

<ul class="calibre6"><li class="calibre7"><code class="calibre9">/etc/gitconfig</code>文件：系统中对所有用户都普遍适用的配置。若使用 <code class="calibre9">git config</code> 时用 <code class="calibre9">--system</code> 选项，读写的就是这个文件。</li>
<li class="calibre7"><code class="calibre9">~/.gitconfig</code>文件：用户目录下的配置文件只适用于该用户。若使用 <code class="calibre9">git config</code> 时用 <code class="calibre9">--global</code> 选项，读写的就是这个文件。</li>
<li class="calibre7">当前项目的 git 目录中的配置文件（也就是工作目录中的 <code class="calibre9">.git/config</code> 文件）：这里的配置仅仅针对当前项目有效。每一个级别的配置都会覆盖上层的相同配置，所以 <code class="calibre9">.git/config</code> 里的配置会覆盖 <code class="calibre9">/etc/gitconfig</code> 中的同名变量。</li>
</ul><p class="calibre2">在 Windows 系统上，Git 会找寻用户主目录下的 <code class="calibre9">.gitconfig</code> 文件。主目录即 <code class="calibre9">$HOME</code> 变量指定的目录，一般都是 <code class="calibre9">C:\Documents and Settings\$USER</code>。此外，Git 还会尝试找寻 /etc/gitconfig 文件，只不过看当初 Git 装在什么目录，就以此作为根目录来定位。</p>

<h3 id="calibre_toc_82" class="calibre4">用户信息</h3>

<p class="calibre2">第一个要配置的是你个人的用户名称和电子邮件地址。这两条配置很重要，每次 Git 提交时都会引用这两条信息，说明是谁提交了更新，所以会随更新内容一起被永久纳入历史记录：</p>

<pre class="calibre8"><code class="calibre9">$ git config --global user.name "John Doe"
$ git config --global user.email johndoe@example.com
</code></pre>

<p class="calibre2">如果用了 <code class="calibre9">--global</code> 选项，那么更改的配置文件就是位于你用户主目录下的那个，以后你所有的项目都会默认使用这里配置的用户信息。如果要在某个特定的项目中使用其他名字或者电邮，只要去掉 <code class="calibre9">--global</code> 选项重新配置即可，新的设定保存在当前项目的 <code class="calibre9">.git/config</code> 文件里。</p>

<h3 id="calibre_toc_83" class="calibre4">文本编辑器</h3>

<p class="calibre2">接下来要设置的是默认使用的文本编辑器。Git 需要你输入一些额外消息的时候，会自动调用一个外部文本编辑器给你用。默认会使用操作系统指定的默认编辑器，一般可能会是 Vi 或者 Vim。如果你有其他偏好，比如 Emacs 的话，可以重新设置：</p>

<pre class="calibre8"><code class="calibre9">$ git config --global core.editor emacs
</code></pre>

<h3 id="calibre_toc_84" class="calibre4">差异分析工具</h3>

<p class="calibre2">还有一个比较常用的是，在解决合并冲突时使用哪种差异分析工具。比如要改用 vimdiff 的话：</p>

<pre class="calibre8"><code class="calibre9">$ git config --global merge.tool vimdiff
</code></pre>

<p class="calibre2">Git 可以理解 kdiff3，tkdiff，meld，xxdiff，emerge，vimdiff，gvimdiff，ecmerge，和 opendiff 等合并工具的输出信息。当然，你也可以指定使用自己开发的工具，具体怎么做可以参阅第七章。</p>

<h3 id="calibre_toc_85" class="calibre4">查看配置信息</h3>

<p class="calibre2">要检查已有的配置信息，可以使用 <code class="calibre9">git config --list</code> 命令：</p>

<pre class="calibre8"><code class="calibre9">$ git config --list
user.name=Scott Chacon
user.email=schacon@gmail.com
color.status=auto
color.branch=auto
color.interactive=auto
color.diff=auto
...
</code></pre>

<p class="calibre2">有时候会看到重复的变量名，那就说明它们来自不同的配置文件（比如 <code class="calibre9">/etc/gitconfig</code> 和 <code class="calibre9">~/.gitconfig</code>），不过最终 Git 实际采用的是最后一个。</p>

<p class="calibre2">也可以直接查阅某个环境变量的设定，只要把特定的名字跟在后面即可，像这样：</p>

<pre class="calibre8"><code class="calibre9">$ git config user.name
Scott Chacon
</code></pre>

</body>
</html>
